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DETAILED ACTION 

1 . Claims 1-5,7, and 9-46 are pending. 

Continued Examination Under 37 CFR 1.114 

2. A request for continued examination under 37 CFR 1 . 1 1 4, including the fee set 
forth In 37 CFR 1 .17(e). was filed in this application after final rejection. Since this 
application is eligible for continued examination under 37 CFR 1.1 14, and the fee set 
forth in 37 CFR 1 .17(e) has been timely paid, the finality of the. previous Office action 
has been withdrawn pursuant to 37 CFR 1.1 14. Applicant's submission filed on 03 
January 2007 has been entered. 

Response to Arguments 

3. Applicant's arguments filed 18 July 2006 have been fully considered but they are 
not persuasive for the reasons set forth below. 

Applicant argues: 

(1) "Neither reference, alone or in combination, teaches or suggests determining 
one or more data stores of a plurality of data stores to service a data access request 
wherein the plurality of data stores comprises at least one relational database and at 
least one LDAP directory." 

The Examiner respectfully disagrees. Burroughs teaches a method for 
partitioning, comprising (i.e. "The preferred embodiment of the present invention provides a system 
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and method is provided that allows transparent and flexible partitioning of created objects in the context of 
schema mapping." The preceding text clearly indicates that partitioning is flexible partitioning of created 
objects.)(Abstract): receiving a data access request, said data access request includes one 
or more variables in a first format (i.e. "The first step 802 of method 800 is when an application 
makes a run time request to create a new owned entity for a specif led owning entity." The preceding text 
clearly indicates that a data access request is a run time request to create a new owned entity and one or 
nnore variable in the first format is inherent in the data object.)(Column 13, lines 32-35); determining 

one or more data stores of a plurality of data stores to service said data access request, 
said step of determining includes accessing one or more mappings of said one or more 
variables to said plurality of data stores and using said mappings to evaluate partition 
expressions for said data stores (i.e. The schema mapping code defines the mapping between 
persistent storage in relational database tables and objects. As discussed above, this mapping preferably 
includes the defining and mapping of both partition key values and partition keys used to partition 
selected tables into two or more partitions. This mapping also defines the mapping of EntityOwningExtent 
(EOE) objects for each partition of each table." The preceding text clearly indicates that one or more data 
stores of a set of data stores are inherent in a relational database tables and objects, one or more 
variables is the entityowningextent (EOE) objects.)(Column 13, lines 22-29); and sending information 
for said data access request to said one or more data stores determined to service said 
data access request (i.e. "The next step 806 is to store the entity data for the owning entity in the 
appropriate row of the appropriate table if the data for the owning entity it has not been previous stored" 
The preceding text clearly indicates that the storing the entity data for the owning entity in the appropriate 
row of the appropriate table is sending information for the said data access request to one or more data 
stores to service the request.)(Column 13, lines 42-44). 
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Burroughs does not explicitly teacli a method wherein said plurality of data stores 
comprises at least one relational database and at least one Lightweight Directory 
Access Protocol (LDAP) directory. 

Shiigi teaches a method wherein said plurality of data stores comprises at least 
one relational database and at least one Lightweight Directory Access Protocol directory 
(i.e. "A Repository Manager 16A translates the logical design used in the system into the structure and 
format of the repository. A Resource Manager 18A stores and manages resources in a Resource 
Repository 54. A repository is typically, but does not have to be, a relational database," In this example, 
the Core System is implemented as a Java application that can run on the following application platforms 
for the various functions required in the system: Operating System; Java Application Server; Relational 
Database; and LDAP Directory Server At the bottommost layer, the Core System runs inside of a 
readily available operating system, such as Microsoft WINDOWS, TM. or freely available GNU/Linux on a 
sen/er computer The application code is written in the Java programming language and runs as a Web 
Application inside of a Web Application Server implementing the J2EE and Java Servlet 2.3 standards. 
Alternatively, a free application server, TomcaV is available from the Jakarta project of the Apache 
Foundation, while commercial application servers are sold by IBM, BEA Systems, and Macromedia Inc. 
among others. The Web Application Sen/eris mn inside of a Java Virtual-Machine (JVM) application that 
sits on top of the underlying computer operating system. JVM implementations are freely available from 
Sun Microsystems and IBM." The preceding text clearly indicates that at least one relational database 
and an LDAP directory exists.)(Paragraphs [0040], [0088]). 

It would have been obvious to a person of ordinary skill in the art at the time of 
Applicant's invention to modify the teachings of Burroughs with the teachings of Shiigi to 
include a method wherein said plurality of data stores comprises at least one relational 
database and at least one Lightweight Directory Access Protocol directory with the 
motivation to integrate relational database systems with object oriented systems that 
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provides for efficient partitioning of objects in the object oriented system. (Burroughs, 
column 3, lines 30-33). 

Hence, the Applicant's arguments do not distinguish over the claimed invention 
over the prior art of record. 

Any other arguments by the applicant are either more limiting than the claimed 
language or completely irrelevant. 

Claim Rejections - 35 USC § 103 

4, The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not Identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

5. Claim1-5, 7, 9-14, 17, 21, 25, 26, 28, 30-35, 39, 44, and 45 are rejected under 35 
U.S.C. 103(a) as being unpatentable over Burroughs et al (U.S. Patent No. 6,341,289 
and known hereinafter as Burroughs) in view of Shiigi et al (U.S. Patent Pub. 
2003/0014442 Al and known hereinafter as Shiigi). 

As per claims 1, 21 , 25 and 28, Burroughs teaches a method for partitioning, 
comprising (i.e. "The preferred embodimer}t of the present invention provides a system and method is 
provided that allows transparent and flexible partitioning of created objects in the context of schema 
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mapping." The preceding text clearly indicates that partitioning is flexible partitioning of created 
objects.)(Abstract): receiving a data access request, said data access request includes one 
or more variables in a first format (i.e. "The first step 802 of method 800 is when an application 

makes a run time request to create a new owned entity for a specified owning entity. " The preceding text 
clearly indicates that a data access request is a run time request to create a new owned entity and one or 
more variable in the first format is inherent in the data object.)(Column 13, lines 32-35); determining 

one or more data stores of a plurality of data stores to service said data access request, 
said step of determining includes accessing one or more mappings of said one or more 
variables to said plurality of data stores and using said mappings to evaluate partition 
expressions for said data stores (i.e. "The schema mapping code defines the mapping between 
persistent storage in relational database tables and objects. As discussed above, this mapping preferably 
includes the defining and mapping of both partition key values and partition keys used to partition 
selected tables into two or more partitions. This mapping also defines the mapping of Entity Owning Extent 
(EOE) objects for each partition of each table." The preceding text clearly indicates that one or more data 
stores of a set of data stores are inherent in a relational database tables and objects, one or more 
variables is the entityowningextent (EOE) objects.)(Column 13, lines 22-29); and sending information 

for said data access request to said one or more data stores determined to service said 
data access request (i.e. "The next step 806 is to store the entity data for the owning entity in the 
appropriate row of the appropriate table if the data for the owning entity it has not been previous stored" 
The preceding text clearly indicates that the storing the entity data for the owning entity in the appropriate 
row of the appropriate table is sending information for the said data access request to one or more data 
stores to service the request.)(Column 13, lines 42-44). 
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Burroughs does not explicitly teach a method wherein said plurality of data stores 
comprises at least one relational database and at least one Lightweight Directory 
Access Protocol (LDAP) directory. 

Shiigi teaches a method wherein said plurality of data stores comprises at least 
one relational database and at least one Lightweight Directory Access Protocol directory 
(i.e. 7\ Repository Manager 16A translates the logical design used in the system into the structure and 
format of the repository. A Resource Manager 18A stores and manages resources in a Resource 
Repository 54, A repository is typically, but does not have to be, a relational database." "In this example, 
the Core System is implemented as a Java application that can run on the following application platforms 
for the various functions required in the system: Operating System; Java Application Sen/er; Relational 
Database; and LDAP Directory Server. At the bottommost layer, the Core System runs inside of a 
readily available operating system, such as Microsoft WINDOWS.TM. or freely available GNU/Unux on a 
server computer The application code is written in the Java programming language and runs as a Web 
Application inside of a Web Application Server implementing the J2EE and Java Servlet 2.3 standards. 
Alternatively, a free application server, ^TomcaV is available from the Jakarta project of the Apache 
Foundation, while commercial application servers are sold by IBM, BEA Systems, and Macromedia Inc. 
among others. The Web Application Server is run inside of a Java Virtual-Machine (JVM) application that 
sits on top of the underlying computer operating system. JVM implementations are freely available from 
Sun Microsystems and IBM." The preceding text clearly indicates that at least one relational database 
and an LDAP directory exists.)(Paragraphs [0040], [0088]). 

It would have been obvious to a person of ordinary skill in the art at the time of 

Applicant's invention to modify the teachings of Burroughs with the teachings of Shiigi to 
include a method wherein said plurality of data stores comprises at least one relational 
database and at least one Lightweight Directory Access Protocol directory with the 
motivation to integrate relational database systems with object oriented systems that 
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provides for efficient partitioning of objects in the object oriented system. (Burroughs, 
column 3. lines 30-33). 

As per claim 2, Burroughs teaches a method wherein: said data access request 
includes a search operation (i.e. "This allows for increased efficiencies because queries can specify 
what partition to search for objects in and avoid searching large amounts of unneeded objects. " The 
preceding text clearly indicates that in order to submit queries a search operation is performed. )(Column 
3, lines 18-21). 

As per claim 3, Burroughs teaches a method wherein: said data access request 
includes adding new data to a data store (i.e. "The next step 806 is to store the entity data for the 
owning entity in the appropriate row of the appropriate table if the data for the owning entity it has not 
been previous stored" The preceding text clearly indicates that if the data for the owning entity has not 
been previous stored means that the entity data, which is new data, is stored in the data store, which is 
the appropriate table.)(Column 13. lines 42-44). 

As per claim 4, Burroughs teaches a method wherein: said data access request 
includes accessing data in multiple data stores (i.e. "FIG. 3 illustrates exemplary persistent data 
stored in Company, Employee and Supplies tables. FIG. 3 also illustrates the type of mapped objects that 
would come from the Company, Employee and Supplies tables. In particular, Company objects, 
Employee objects and Supplies objects. As a general rule, each table corresponds to a class of objects 
(i.e., a company class, an employee class and a supplies class) and each row in the table corresponds to 
an instantiated object from the corresponding class. " "Storing partitioning information as part of primary 
key of object allows queries to performed against a partition without requiring the user to have any 
specific knowledge of the partitioning structure." The preceding text clearly indicates that multiple data 
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stores are company, employee, and supplies tables and data access request is a query. )(Column 9, lines 
56-64; column 11. lines 46-48). 

As per claim 5, Burroughs teaches a method wherein: said data access request 
includes accessing data in only one data store (i.e. Tor example, if the new owned entity is a 

new employee object for a new company object, data for that new company object would need to first be 
stored in the a new row in the company table. " The preceding text clearly indicates that data access 
request includes accessing data in only one data store, which is the company table.)(Column 13, lines 46- 
48). 

As per claim 7, Burroughs teaches a method wherein: said plurality of data stores 
includes at least two relational databases (i.e. "Relational databases have thus been commonly 
used to facilitate the efficient storage and retrieval of data. " The preceding text clearly indicates that there 
is exists more than one relational database that includes set of data stores, which are tables within a 
relational database.)(Column 2, lines 47-48). 

As per claims 9, 22, 26, 30, 39 and 44. Burroughs teaches a method wherein: 
said step of sending includes translating said data access request to a format suitable 
for said relational database and communicating said translated data access request to 
said relational database (i.e. "The schema mapper is responsible for converting the partitioning key 
into a set of columns in the table. Therefore, it must be left up to the schema mapper to pn>vide this 
additional where clause." The preceding text clearly indicates that a schema mapper translates the data 
access request to a format suitable for a relational database)(Column 12, lines 45-49). 
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As per claims 10, 31 and 45, Burroughs teaches a method further comprising: 
receiving a result from said relational database (i.e. 7a? response to this request all of the data 
necessary to fill in the object is retrieved from the relational database 122. " The preceding text clearly 
indicates that retrieving a response is receiving a result from the relational database.)(Column 9, lines 20- 
21). 

As per claims 1 1 and 32, Burroughs teaches a method further comprising: 
receiving a result from said relational database (i.e. in response to this request all of the data 

necessary to fill in the object is retrieved from the relational database 122," The preceding text clearly 
indicates that retrieving a response is receiving a result from the relational database.)(Column 9, lines 20- 
21); and translating said result to said logical object class format (i.e. "Thus, although the 

objects are ultimately stored in the legacy relational format the storage format is transparent to the 
application program which can access the objects using object oriented techniques/' The preceding text 
cleariy indicates that the results are stored in a logical class format, which is the storage format.)(Column 
3. lines 7-11). 

As per claims 12 and 33, Burroughs teaches a method wherein: said data access 
request is from an Identity System (i.e. "Thus, what is a needed is a mechanism for integrating 
relational database systems with object oriented systems that provides for efficient partitioning of objects 
in the object oriented system. " The Identity System is an example of an object-oriented system and is an 
intended use of the prior art.)(Column 3, lines 31-34). 

As per claims 13 and 34, Burroughs teaches a method wherein: said data access 
request is from an Identity and Access System (i.e. "Thus, what is a needed is a mechanism for 
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integrating relational database systems with object oriented systems that provides for efficient partitioning 
of objects in the object oriented system." The Identity System is an example of an object-oriented system 
and is an intended use of the prior art.)(Column 3, lines 31-34). 

As per claims 14 and 35, Burroughs teaches a method wherein: said plurality of 
data stores store identity information (i.e. "Each class of the object includes one or more attributes 

that conespond to one or more columns in the conesponding table. In the illustrated example, the 
company object includes an ivCompCode attribute and an ivCompName attribute that corresponds to the 
CompCode and CompName column respectively," The preceding text clearly indicates that ivCompCode, 
ivCompName are attributes, which are identity information that is stored in the data store, which are 
tables.)(Column 10, lines 3-8). 

As per claim 17, Burroughs teaches a method wherein: said step of sending 
includes creating a custom filter for said data access request that is customized for said 
relational database to only include one or more variables mapped to said relational 
database (i.e. To facilitate the most flexible schema mapping and partitioning, the partition key value 
for an object can be defined by the developer to be an attribute of an owning object, a primary key field of 
an owning object, or constant defined for its class. When new owned objects are created the partition key 
values are retrieved from their specified location in the owning object to determine the partition in which 
the new owned object belongs. In the preferred embodiment the developer also specifies a corresponding 
column of fields in the owned objects table to store the partitioning key values. Preferably, the partitioning 
key values are stored as a subset of the primary key field for the owned object. Because the primary key 
field is used to uniquely identify the corresponding object, the partition information in the partition key 
value partially determines the unique identifier of the owned object." The preceding text clearly indicates 



Application/Control Number: 10/682,330 
Art Unit: 2165 



Page 12 



that partitioning key values inherently uses a customer filter to allow customized mapping of the relational 
database.)(Abstract). 

6. Claims 15, 16, and 23 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Burroughs et al (U.S. Patent No. 6,341 ,289 and known hereinafter as 
Burroughs) in view of Shiigi et al (U.S. Patent Pub. 2003/0014442 Al and known 
hereinafter as Shiigi) and in further view of Bachmann et al (U.S. Patent No. 6,085,188 
and known hereinafter as Bachmann). 

As per claims 15 and 23, Burroughs and Shiigi do not explicitly teach a method 
wherein: said partition expressions are in LDAP filter fomiat. 

Bachmann teaches a method wherein: said partition expressions are in LDAP 
format (i.e. "As seen in FIG. 5. the LDAP naming hierarchy includes a number of entries or nodes, with 
each entry or node represented by a unique entry identifier (EID). Thus, for example, the root node has 
an EID=1. Root has two (2) children, entry GB ('Great Britain"^ having an EID=2, and entry US ("United . 
States") having an EID=3. Child node US itself has two (2) children, 0=IBM (with EID=4) and 
0=Netscape (with EID=5). The remainder of the naming directory includes several additional entries at 
further sublevels.' The preceding text clearly indicates that LDAP format is the EID.)(Column 5, lines 13- 
21). 

It would have been obvious to a person of ordinary skill in the art at the time of 
Applicant's invention to modify the teachings of Burroughs with the teachings of Shiigi 
and further with the teachings of Bachmann to include a method wherein said partition 
expressions are in LDAP format with the motivation to integrate relational database 
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systems with object oriented systems that provides for efficient partitioning of objects in 
the object oriented system. (Burroughs, column 3, lines 30-33). 

As per claim16, Burroughs and Shiigi do not explicitly teach a method wherein: 
said first fomiat is a logical object class format that is compatible with LDAP filter format. 

Bachmann teaches a method wherein: said first fomiat is a logical object class 
format that is compatible with LDAP filter format (i.e. in a preferred embodiment each LDAP 
attribute that can be searched by the user is mapped to an attribute relation that consists of two columns: 
BID and normalized attribute value. As described above, each LDAP entry is assigned a unique identifier 
(BID). Based on the attribute syntax, the attributes are converted (or nomialized) so that the invention can 
apply Structured Query Language (SQL) queries to the attribute values. For example, if the attribute 
syntax is case insensitive (CIS), the attribute value will be converted to all upper case and stored in an 
attribute table. The attribute table is used mainly for search operations to find the entries that match the 
filter criteria. The actual entry data is preferably stored in an Idap.sub.- entry table, as will be described. 
Thus, the generated SQL queries use the attribute table to locate the entry EIDs that match the filter 
expression. Then, the BIDs are used to retrieve the entry data from the Idap.sub.- entry table."){Co\umr\ 
6, lines 26-41). 

It would have been obvious to a person of ordinary skill in the art at the time of 
Applicant's invention to modify the teachings of Burroughs with the teachings of Shiigi 
and further with the teachings of Bachmann to include a method wherein said first 
format is a logical object class format that is compatible with LDAP filter format with the 
motivation to integrate relational database systems with object oriented systems that 
provides for efficient partitioning of objects in the object oriented system. (Burroughs, 
column 3, lines 30-33). 
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7. Claims 18, 19, 24, 27, 29, 36, 38, 40-43, and 46 are rejected under 35 U.S.C. 
103(a) as being unpatentable over Burroughs et al (U.S. Patent No. 6,341,289 and 
known hereinafter as Burroughs) in view of Shiigi et al (U.S. Patent Pub. 2003/0014442 
Al and known hereinafter as Shiigi) and in further in view of Mullins (U.S. Patent No. 
6,999,956). 

As per claim 18, Burroughs and Shiigi do not explicitly teach a method wherein: 
said data access request includes a filter; said filter includes said one or more variables; 
and said using of said mappings to evaluate partition expressions for said data stores 
includes determining whether said filter overlaps with said partition expressions based 
on said mappings. 

Mullins teaches a method wherein: said data access request includes a filter (i.e. 

"This allows more developer control as to how datasets are exchar\ged, filtered and/or validated between 
a first data source and a second data source. " The preceding text clearly indicates that a data access 
request may include a filter, where data access request are datasets.)(Column 25, lines 31-34); said 

filter includes said one or more variables; and said using of said mappings to evaluate 
partition expressions for said data stores includes determining whether said filter 
overlaps with said partition expressions based on said mappings (i.e. "There are distinctive 
advantages when using a dynamic mapping layer where a Java object provides translation by mapping 
such objects of a first data source (relational or object database) and also mapping such object to an XML 
or other second format data source," The preceding text clearly indicates that a filter is used to map 
between data stores, which are within a relational database and partition expressions which are java 
objects.)(Column 24, lines 27-34). 
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It would have been obvious to a person of ordinary skill in the art at the time of 
Applicant's invention to modify the teachings of Burroughs with the teachings of Shiigi 
and further with the teachings of Mullins to include a method wherein: said data access 
request includes a filter; said filter includes said one or more variables; and said using of 
said mappings to evaluate partition expressions for said data stores includes 
detemiining whether said filter overlaps with said partition expressions based on said 
mappings with the niotivation to integrate relational database systems with object 
oriented systems that provides for efficient partitioning of objects in the object oriented 
system. (Burroughs, column 3, lines 30-33). 

As per claims 19, 29, 36, 40 and 43, Burroughs and Shiigi do not explicitly teach 
a method wherein determining whether said filter overlaps with said partition 
expressions based on said mappings comprises: detemiining whether child sub-filters of 
said filter expression overlap with said partition expressions and combining results of 
said determination of whether child sub-filters overlap to determine whether said filter 
expression overlaps with said partition expressions, if said filter expression is a 
composite expression. 

Mullins teaches a method wherein determining whether said filter overlaps with 
said partition expressions based on said mappings comprises: determining whether 
child sub-filters of said filter expression overlap with said partition expressions and 
combining results of said determination of whether child sub-filters overlap to determine 
whether said filter expression overlaps with said partition expressions, if said filter 
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expression is a composite expression (i.e. "There are distinctive advaritages wher) using a 
dynamic mapping layer where a Java object provides translation by mapping such objects of a first data 
source (relational or object database) and also mapping such object to an XML or other second format 
data source." J\)e preceding text clearly indicates that a filter is used to map between data stores, which . 
are within a relational database and partition expressions which are Java objects.)(Column 24, lines 27- 
34). 

It would have been obvious to a person of ordinary skill in the art at the time of 
Applicant's Invention to modify the teachings of Burroughs with the teachings of Shiigi 
and further with the teachings of Mullins to include a method wherein determining 
whether said filter overtaps with said partition expressions based on said mappings 
comprises: determining whether child sub-filters of said filter expression overlap with 
said partition expressions and combining results of said determination of whether child 
sub-filters overlap to determine whether said filter expression overlaps with said 
partition expressions, if said filter expression is a composite expression with the 
motivation to integrate relational database systems with object oriented systems that 
provides for efficient partitioning of objects in the object oriented system. (Burroughs, 
column 3, lines 30-33). 

As per claims 24 27, 38, and 42 Burroughs and Shiigi do not explicitly teach a 
method wherein detemiining whether said filter overtaps with said partition expressions 
based on said mappings comprises: performing a partition compare function using said 
filter expression and a first partition expression to determine whether said filter 
expression overlaps with said first partition expression, if said filter expression and said 
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first partition expression are both simple expressions; and performing said partition 
compare function by treating said filter expression as an input partition expression and 
treating said first partition expression as an input filter expression in order to determine 
whether said filter expression overlaps said first partition expression, if said first partition 
expression is a composite expression. 

Mullins teaches a method wherein determining whether said filter overlaps with 
said partition expressions based on said mappings comprises: performing a partition 
compare function using said filter expression and a first partition expression to 
detemiine whether said filter expression overlaps with said first partition expression, if 
said filter expression and said first partition expression are both simple expressions (i.e. 

TIG. 2 starts at position lA (Start/End) witli a request step 2A from ar) object applicatior) (101 in FIG. 1), 
which calls the CocoBase DataSource Manager and Abstraction layer (hereafter CocoBase system) and 
delegates the database accessing to CocoBase. The logical loop that the CocoBase system performs 
begins in response to the request step (2A) and first performs the Extract Object Name step (4). The 
CocoBase system loop continues onward to the Evaluate Object Properties step (5) and its associated 
components where (i) object properties are evaluated (5), (ii) object to relational maps are accessed, 
created, or updated by 3B (and this may involve retrieving maps from the system DataStore 3C or from a 
separate Optional Maps Files Storage facility (1C)), and (Hi) database commands necessary for data 
retrieval (including SQL strings) are generated at step 2B under the control of the Execution Status 
Monitor (IB), before the CocoBase system continues onward to the Obtain Data step (6). In step 6, the 
CocoBase system in coordination with components 1B, 2B and 3B, passes SQL strings or other 
DataBase Access Statements from 2B to the JDBC Driver (2C), which obtains data from the system 
DataStore (3C) and passes that data to the CocoBase system. ')(Column 14, lines 61-67; column 15, lines 
1-14); and performing said partition compare function by treating said filter expression as 
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an input partition expression and treating said first partition expression as an Input filter 
expression in order to detemnine whether said filter expression overlaps said first 
partition expression, if said first partition expression is a composite expression (i.e. "Then 

the CocoBase system places the obtained data in an object (Step 6A, Place Data in Object and sends the 
Data Object (Step 7A, Send Data Object) to the Requestor Object Application (back to Step 2A position) 
and the delegation to the CocoBase system by the Object Application ends (back to Step 1>4;/)(Column 
15, lines 14-19). 

It would have been obvious to a person of ordinary skill in the art at the time of 
Applicant's Invention to modify the teachings of Burroughs with the teachings of Shiigi 
and further with the teachings of Mullins to include a method wherein determining 
whether said filter overlaps with said partition expressions based on said mappings 
comprises: performing a partition compare function using said filter expression and a 
first partition expression to determine whether said filter expression overlaps with said 
first partition expression, if said filter expression and said first partition expression are 
both simple expressions; and performing said partition compare function by treating said 
filter expression as an input partition expression and treating said first partition 
expression as an input filter expression In order to determine whether said filter 
expression overlaps said first partition expression, if said first partition expression is a 
composite expression with the motivation to integrate relational database systems with 
object oriented systems that provides for efficient partitioning of objects in the object 
oriented system. (Burroughs, column 3. lines 30-33). 
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As per claims 37, 41 , and 46, Burroughs and Shilgi do not explicitly teach a 
method wherein said step of providing comprises: removing terms not supported by a 
first data source from said information for said filter expression provided to said first 
data source. 

Mullins teaches a method wherein said step of providing comprises: removing 
terms not supported by a first data source from said infonnation for said filter expression 
provided to said first data source (i.e. "Once the XML file is written, it can be edited using a 

standard text editor or XML editor, and can be modified to reflect map customization requirements, Tlie 
following discussion relates to specific features of the generated XML file. The basic repository format has 
CBObject (CocoBase object class) definitions that reflect the select, insert, update, delete and call related 
'map definitions for a CocoBase map. Each of those operations further consists of tables, fields and 
clauses that may exist to specify how the object is mapped to and from the data source. 'XColumn 14, 
lines 6-15). 

It would have been obvious to a person of ordinary skill in the art at the time of 
Applicant's invention to modify the teachings of Burroughs with the teachings of Shiigi 
and further with the teachings of Mullins to include a method wherein said step of 
providing comprises: removing terms hot supported by a first data source from said 
information for said filter expression provided to said first data source with the 
motivation to integrate relational database systems with object oriented systems that 
provides for efficient partitioning of objects in the object oriented system. (Burroughs, 
column 3, lines 30-33). 
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Allowable Subject Matter 



8. Claim 20 is objected to as being dependent upon a rejected base claim, but 
would be allowable if rewritten in independent form including all of the limitations of the 
base claim and any intervening claims. 
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